//定制请求的实例

//导入axios  npm install axios
import axios from 'axios';
import { ElMessage } from 'element-plus'
import { useTokenStore } from '@/stores/token';
//import { useRoute } from 'vue-router';
//const router  =  useRoute()
//定义一个变量,记录公共的前缀  ,  baseURL
//const baseURL = 'http://localhost:8080';
import router from '@/router';

const baseURL = '/api';
const instance = axios.create({baseURL})

//添加请求拦截器
instance.interceptors.request.use(
    (config)=>{
        //请求前的回调
        const tokenStore = useTokenStore()
        //判断有没有token
        if (tokenStore.token){
            config.headers.Authorization = tokenStore.token
        }
        return config;
    },
    (err)=>{
        //请求错误的回调
        Promise.reject(err)
    }
)

//添加响应拦截器
instance.interceptors.response.use(
    result=>{
        //判断业务状态码
        if(result.data.code===0){
            return result.data;
        }
        //操作失败
        ElMessage.error(result.data.message?result.data.message:"服务器异常")
        //异步操作的状态转化为失败
        return Promise.reject(result.data);
    },
    err=>{
        if(err.response){
            const tokenStore = useTokenStore()
            //判断响应状态码，如果为401则为未登录，提示请登录并跳转到登录页面
            if(err.response.status===401){
                tokenStore.removeToken()
                ElMessage.error("请先登录")
                router.push('/login')
            }else{
                ElMessage.error('服务异常');
            }
        }else{
            ElMessage.error('网络连接异常');
        }
        return Promise.reject(err);//异步的状态转化成失败的状态
    }
)

export default instance;